﻿<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title>员工管理</title>
    <#include "/common/link.ftl">

</head>
<body class="hold-transition skin-black sidebar-mini">
<div class="wrapper">
    <#include "/common/navbar.ftl">
    <!--菜单回显-->
    <#assign currentMenu="employee"/>
    <#include "/common/menu.ftl">
    <div class="content-wrapper">
        <section class="content-header">
            <h1>员工编辑</h1>
        </section>
        <section class="content">
            <div class="box">
                <form class="form-horizontal" action="/employee/saveOrUpdate" method="post" id="editForm" >
                    <input type="hidden" name="id" value="${employee.id}">
                    <div class="form-group" style="margin-top: 10px;">
                        <label class="col-sm-2 control-label">用户名：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" name="username"  placeholder="请输入用户名" value="${employee.username}" <#if employee ??>disabled</#if>>
                        </div>
                    </div>
                    <div class="form-group" style="margin-top: 10px;">
                        <label class="col-sm-2 control-label">真实姓名：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" name="name"  placeholder="请输入真实姓名" value="${employee.name}">
                        </div>
                    </div>
                        <#--编辑不应该显示密码 ,对象 ?? 判断是否有值,如果有就为true ,-->
                        <#if !(employee ??)>
                    <div class="form-group">
                        <label for="password" class="col-sm-2 control-label">密码：</label>
                        <div class="col-sm-6">
                            <input type="password" class="form-control" id="password" name="password" placeholder="请输入密码" value="${employee.password}">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="repassword" class="col-sm-2 control-label">验证密码：</label>
                        <div class="col-sm-6">
                            <input type="password" class="form-control" id="repassword" name="repassword" placeholder="再输入一遍密码">
                        </div>
                    </div>
                        </#if>
                    <div class="form-group">
                        <label for="email" class="col-sm-2 control-label">电子邮箱：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control"  name="email" placeholder="请输入邮箱" value="${employee.email}">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="age" class="col-sm-2 control-label">年龄：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" name="age" placeholder="请输入年龄" value="${employee.age}">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="dept" class="col-sm-2 control-label">部门：</label>
                        <div class="col-sm-6">
                            <select class="form-control" id="dept" name="dept.id">
                                <option value="">全部</option>
                                <#list departments as dept>
                                    <option value="${dept.id}">${dept.name}</option>
                                </#list>
                                <script>
                                    $('#dept').val(${employee.dept.id})
                                </script>

                            </select>
                        </div>
                    </div>
                    <div class="form-group" id="adminDiv">
                        <label for="admin" class="col-sm-2 control-label">超级管理员：</label>
                        <div class="col-sm-6"style="margin-left: 15px;">
                            <input type="checkbox" ${((employee.admin)?string('checked',''))!} id="admin" name="admin" class="checkbox" value="${employee.admin}">
                                 <script>
                                     if ($(".checkbox")){
                                         $('#admin').val("1")
                                     }else {
                                         $('#admin').val("0")
                                     }
                                 </script>
                        </div>
                    </div>
                    <div class="form-group" id="roleDiv">
                        <label for="role" class="col-sm-2 control-label">分配角色：</label><br/>
                        <div class="row" style="margin-top: 10px">
                            <div class="col-sm-2 col-sm-offset-2">
                                <select multiple class="form-control allRoles" size="15">
                                    <#list roles as r>
                                      <option value="${r.id}">${r.name}</option>
                                    </#list>
                                    <script>

                                    </script>
                                </select>
                            </div>

                            <div class="col-sm-1" style="margin-top: 60px;" align="center">
                                <div>

                                    <a type="button" class="btn btn-primary  " style="margin-top: 10px" title="右移动"
                                       onclick="moveSelected('allRoles', 'selfRoles')">
                                        <span class="glyphicon glyphicon-menu-right"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="左移动"
                                       onclick="moveSelected('selfRoles', 'allRoles')">
                                        <span class="glyphicon glyphicon-menu-left"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全右移动"
                                       onclick="moveAll('allRoles', 'selfRoles')">
                                        <span class="glyphicon glyphicon-forward"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全左移动"
                                       onclick="moveAll('selfRoles', 'allRoles')">
                                        <span class="glyphicon glyphicon-backward"></span>
                                    </a>
                                </div>
                            </div>

                            <div class="col-sm-2">
                                <select multiple class="form-control selfRoles" size="15" name="ids">
                                    <#list employee.roles as r>
                                        <option value="${r.id}">${r.name}</option>
                                    </#list>
                                </select>
                            </div>
                        </div>
                    </div>

                    <div class="form-group">
                        <div class="col-sm-offset-1 col-sm-6">
                            <button type="button" class="btn btn-primary btn-submit">保存</button>
                            <a href="javascript:window.history.back()" class="btn btn-danger">取消</a>
                        </div>
                    </div>

                </form>

            </div>
        </section>
    </div>
    <#include "/common/footer.ftl">
    <script>
        function moveSelected(src,target) {
            //获取选中的数据,获取下拉框中为选中的option
            let options = $("."+src+"> option:selected");
            //移动到目标框下
            $("."+target).append(options);
        }
        //移动所有
        function moveAll(src,target) {
            //获取选中的数据,获取下拉框中为选中的option
            let options = $("."+src+"> option");
            //移动到目标框下
            $("."+target).append(options);
        }
        //保存按钮
        $(".btn-submit").click(function () {
            //让右边的option全部选中
            $('.selfRoles > option').prop('selected',true)
            //提交表单
            $("#editForm").submit();
        });

        let roleDiv;
        //如果勾选了超管复选框就隐藏角色属性,如果取消了就恢复
        $('#admin').click(function () {
            //获取复选框状态
            let checked = $(this).prop('checked');
            if (checked){
                //如果是选中的就删除roleDiv 角色属性
                 roleDiv = $('#roleDiv').remove();
            }else{
                //否则就添加角色属性再超管后面
                $('#adminDiv').after(roleDiv)
            }
        });
        //页面加载完在判断是否为管理员
        let checked = $('#admin').prop('checked');
        if (checked){
            //如果是选中的就删除roleDiv 角色属性
            roleDiv = $('#roleDiv').remove()
        }
        //获取右边的角色id,存放到数组
        let ids=[];
        $('.selfRoles > option').each(function (index,ele) {
            ids.push($(ele).val())

        });
        //获取左边的角色id,遍历每个元素是否已经存在ids中
        $('.allRoles > option').each(function (index,ele) {
            let id=$(ele).val();
            if ($.inArray(id,ids)>-1){
                //如果存在就删除自己
                $(ele).remove();
            }
        });

        //完善员工表单数据验证
        $("#editForm").bootstrapValidator({
            feedbackIcons: { //图标
                valid: 'glyphicon glyphicon-ok',
                invalid: 'glyphicon glyphicon-remove',
                validating: 'glyphicon glyphicon-refresh'
            },

            fields:{ //配置要验证的字段
                //判断用户名是否存在
                username:{
                    validators:{
                        remote: { //远程验证
                            type: 'POST', //请求方式
                            url: '/employee/checkUsername', //请求地址
                            message: '用户名已经存在', //验证不通过时的提示信息
                            delay: 200, //输入内容后多久发请求
                            data: function() {  //自定义提交多个参数，默认只会提交当前用户名input的参数
                                return {
                                    id: $('[name="id"]').val(),
                                    username: $('[name="username"]').val()
                                };
                            },
                        }
                    }
                },

                name:{
                    validators:{ //验证的规则
                        notEmpty:{ //不能为空
                            message:"用户名必填" //错误时的提示信息
                        },
                        stringLength: { //字符串的长度范围
                            min: 1,
                            max: 5
                        }
                    }
                },
                password:{
                    validators:{
                        notEmpty:{ //不能为空
                            message:"密码需必填" //错误时的提示信息
                        },
                    }
                },
                repassword:{
                    validators:{
                        notEmpty:{ //不能为空
                            message:"密码需必填" //错误时的提示信息
                        },
                        identical: {//两个字段的值必须相同
                            field: 'password',
                            message: '两次输入的密码必须相同'
                        },
                    }
                },
                email: {
                    validators: {
                        emailAddress: {} //邮箱格式
                    }
                },
                age:{
                    validators: {
                        between: { //数字的范围
                            min: 18,
                            max: 60
                        }
                    }
                }
            }
        }).on('success.form.bv', function() { //表单所有数据验证通过后执行里面的代码
            //提交异步表单(使用ajax是不会触发验证的)
            $.post("/employee/saveOrUpdate",$("#editForm").serialize(),function (data) {
                if (data.success){
                    console.log(data);
                    Swal.fire({
                        title:'保存成功',
                        icon:'success',

                    }).then(()=>{
                        window.location.href="/employee/list";
                    })
                }else {
                    Swal.fire("保存失败",data.msg,'error')
                }
            })

        });


    </script>
</div>
</body>
</html>
